草庐IT

c++ - constexpr 和 ODR

全部标签

c++ - 重用 bindBufferBase 和 OpenGL 计算着色器

我正在尝试在OpenGL中构建计算着色器以执行骨架化算法。我已经在仅CPU版本中测试了该算法,它在那里是正确的。但是,我在将它移植到计算着色器代码时遇到了一些问题。问题是,无论我运行了多少次计算着色器调用,第一次调用后输出都不会改变。事实上,如果我在while循环结束时取出检查,程序永远不会终止。我有两个内存区域用于输入和输出。我试图在主while循环中使用glBindBufferBase()做一个技巧,我在其中交换它们中的两个(最后一轮的输出成为当前一轮的输入)。请参阅main.cpp中的第270-318行。这样我就不会多次在CPU和GPU之间来回复制数据。所以,我的问题是:1)我可

c++ - C 编译 : error: stray '\4' in program ; octal flow?

正在尝试编译大量.c文件(1)文件编译正常,使用cccc-Wall-Wextra-Wunreachable-code-ggdb-O0*.c(2)然后,我需要根据最终输出创建一个静态库,以在C++程序中使用。所以我这样做:arcruliborientdb-c.a*.o(3)工作正常。但是,当我编译包含第1行库的c++程序testme.cpp时(line1oftestme.cpp)#include"liborientdb-c.a"编译步骤:cctestme.cpp我收到这个错误:liborientdb-c.a:117:22:error:stray'\3'inprogramliborient

c++ - constexpr lambda/‘x’ 没有命名类型;你是说 ‘x’ 吗?

我正在尝试使用C++17的constexprlambdas来获取编译时字符串:#includetemplatestructstr{constexprautooperator==(conststr&)const{returntrue;}voidfoo()const;};templateconstexprautomake_str(Ss,std::index_sequence){returnstr{};}#defineLIT(s)\make_str([](){returns;},std::make_index_sequence{})constexprautox=LIT("hansi");co

c++ - 使用 mpirun/mpiexec 运行时检测不使用 MPI

我正在编写一个程序(在C++11中),可以选择使用MPI并行运行。该项目使用CMake进行配置,如果找不到MPI,CMake会自动禁用MPI并显示相关警告消息。但是,我担心一个非常合理的用例,即用户在HPC集群上配置和编译程序,忘记加载MPI模块,并且没有注意到警告。然后同一用户可能会尝试运行该程序,注意未找到mpirun,包括MPI模块,但忘记重新编译。如果用户随后使用mpirun运行该程序,这将起作用,但该程序将只运行多次而没有任何并行化,因为MPI在编译时被禁用。为了防止用户认为程序是并行运行的,我想让程序在这种情况下显示一条错误消息。我的问题是:如何在不使用MPI库函数的情况下

c++ - 如何使用 msgfmt 验证格式字符串中的位置符号占位符?

在翻译文本中使用类似printf的格式字符串时,msgfmt--check检查翻译是否仍然包含占位符。例如,在以下代码上运行xgettextprintf(gettext("string:%s,int:%d"),str,i)生成一个.po文件,其中msgid标记为c-format并且其值为"string:%s,整数:%d"。如果翻译者在翻译中忘记了%s或%d,则msgfmt会提示:numberofformatspecificationsin'msgid'and'msgstr'doesnotmatch不幸的是,此检查不适用于使用位置符号的格式字符串,例如boost::format(gett

c++ - 为什么 malloc 不返回?

我有一个正在运行的线程(OSX10.10.5)与此堆栈跟踪一起挂起。它是在运行约20小时后出现的,可能与内存不足有关。但是,问题是,为什么malloc不直接返回null?为什么线程的执行需要停止?实际请求的字节数很少(对于路径上的字符串操作)。std::wstringfinalPath=itsPath.substr(0,ls+1);1operatornew(unsignedlong)+37(libc++abi.dylib+124485)[0xa0339645]21malloc+29(libsystem_malloc.dylib+3997)[0xa1829f9d]21malloc_zon

c++ - 从 C 代码调用具有复杂参数和复杂返回类型的 C++ 函数

我有一个C++数学库并用Rust编写了一个项目。由于无法直接从Rust调用C++,但可以调用C,因此我决定编写一个从C++到C的标准包装器。除具有复杂参数的函数外,一切都或多或少地按预期工作,其中虚部由于某种原因丢失。下面我提供mwe。export_c++.h#ifdef__cplusplus#includestd::complexfoo(conststd::complexa);#endif#ifdef__cplusplusextern"C"{#endif#includedouble_Complexc_foo(constdouble_Complexa);#ifdef__cplusplu

c - 开关盒奇怪的范围

在查看一些第3方C代码时,我发现了类似的东西:switch(state){case0:if(c=='A'){//openbrace//code...break;//bracenotclosed!case1://code...break;}//closebrace!case2://code...break;}在我审查的代码中,这似乎只是一个拼写错误,但令我惊讶的是它编译没有错误。为什么这个C有效?与在预期位置关闭大括号相比,这段代码的执行效果如何?这在任何情况下都有用吗?编辑:在示例中,我查看了所有中断都存在(如上所述)-但如果在0或1的情况下中断不存在,则答案也可能包括行为。

c++ - constexpr if 和 static_assert

P0292R1constexprif一直included,在C++17的轨道上。它似乎很有用(并且可以替代SFINAE的使用),但是关于static_assert的评论是错误的,不需要诊断在false分支中吓到我了:Disarmingstatic_assertdeclarationsinthenon-takenbranchofaconstexprifisnotproposed.voidf(){ifconstexpr(false)static_assert(false);//ill-formed}templatevoidg(){ifconstexpr(false)static_asser

c++ - C++17 中的 "If constexpr"在非模板函数中不起作用

我尝试使用C++17标准。我尝试使用C++17ifconstexpr的功能之一。我有一个问题......请看下面的代码。这编译没有错误。在下面的代码中,我尝试使用ifconstexpr来检查它是否是一个指针。#include#includetemplatevoidprint(Tvalue){ifconstexpr(std::is_pointer_v)std::cout但是当我重写上面的代码时,如下所示,其中ifconstexpr在main函数中:#include#includeintmain(){autovalue=100;ifconstexpr(std::is_pointer_v)s